"""
945. 使数组唯一的最小增量
已解答
中等
相关标签
相关企业
给你一个整数数组 nums 。每次 move 操作将会选择任意一个满足 0 <= i < nums.length 的下标 i，并将 nums[i] 递增 1。

返回使 nums 中的每个值都变成唯一的所需要的最少操作次数。

生成的测试用例保证答案在 32 位整数范围内。



示例 1：

输入：nums = [1,2,2]
输出：1
解释：经过一次 move 操作，数组将变为 [1, 2, 3]。
示例 2：

输入：nums = [3,2,1,2,1,7]
输出：6
解释：经过 6 次 move 操作，数组将变为 [3, 4, 1, 2, 5, 7]。
可以看出 5 次或 5 次以下的 move 操作是不能让数组的每个值唯一的。


提示：
1 <= nums.length <= 105
0 <= nums[i] <= 105
"""


class Solution(object):
    def minIncrementForUnique(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        nums.sort()
        ans = 0
        for i in range(1, len(nums)):
            #如果当前比左边实际的数要小，则当前要改为左边的数+1
            if nums[i] <= nums[i-1]:
                ans += nums[i-1] - nums[i] + 1
                #当前实际取的数，用于下次比较
                nums[i] = nums[i-1] + 1
        return ans

if __name__ == '__main__':
    print(Solution().minIncrementForUnique([1,2,2]))
    nums = [3,2,1,2,1,7]
    print(Solution().minIncrementForUnique(nums))